<script>
import UserAvatar from './profile/UserAvatar.vue'
import UserInfo from './profile/UserInfo.vue'
import ResetPwd from './profile/ResetPwd.vue'
export default {
  name: 'Personal',
  components: { UserAvatar, UserInfo, ResetPwd },
  data() {
    return {
      user: {},
      roleGroup: {},
      postGroup: {},
      activeTab: 'userinfo',
      loading: false
    }
  },
  methods: {
    async getUserInfo() {
      this.loading = true
      try {
        let { code, data, postGroup, roleGroup, socialGroup } = await this.$API.queryUserInfo()
        if (+code === 200) {
          this.user = Object.freeze(data)
          this.roleGroup = Object.freeze(roleGroup)
          this.postGroup = Object.freeze(postGroup)
        }
      } catch (_) { }
      this.loading = false
    }
  },
  created() {
    this.getUserInfo()
  }
}
</script>

<template>
  <div class="personal-box">
    <el-row :gutter="20">
      <el-col :span="6" :xs="24">
        <el-card class="box-card" v-loading="loading">
          <div slot="header" class="clearfix">
            <span>个人信息</span>
          </div>
          <div>
            <div class="text-center">
              <UserAvatar v-if="user.avatar" :avatar="user?.avatar" />
            </div>
            <ul class="list-group list-group-striped">
              <li class="list-group-item">
                <i class="el-icon-user-solid">用户名称</i>
                <div class="pull-right">{{ user.userName }}</div>
              </li>
              <li class="list-group-item">
                <i class="el-icon-phone">手机号码</i>
                <div class="pull-right">{{ user.phonenumber }}</div>
              </li>
              <li class="list-group-item">
                <i class="el-icon-s-promotion">用户邮箱</i>
                <div class="pull-right">{{ user.email }}</div>
              </li>
              <li class="list-group-item">
                <i class="el-icon-s-management">所属部门</i>
                <div class="pull-right" v-if="user.dept">{{ user.dept.deptName }} / {{ postGroup }}</div>
              </li>
              <li class="list-group-item">
                <i class="el-icon-s-custom">所属角色</i>
                <div class="pull-right">{{ roleGroup }}</div>
              </li>
              <li class="list-group-item">
                <i class="el-icon-time">创建日期</i>
                <div class="pull-right">{{ user.createTime }}</div>
              </li>
            </ul>
          </div>
        </el-card>
      </el-col>
      <el-col :span="18" :xs="24">
        <el-card>
          <div slot="header" class="clearfix">
            <span>基本资料</span>
          </div>
          <el-tabs v-model="activeTab">
            <el-tab-pane label="基本资料" name="userinfo">
              <UserInfo :user="user" @update="getUserInfo" />
            </el-tab-pane>
            <el-tab-pane label="修改密码" name="resetPwd">
              <ResetPwd />
            </el-tab-pane>
          </el-tabs>
        </el-card>
      </el-col>
    </el-row>
  </div>
</template>

<style lang="less" scoped>
.list-group-striped>.list-group-item {
  display: flex;
  justify-content: space-between;
  border-left: 0;
  border-right: 0;
  border-radius: 0;
  padding-left: 0;
  padding-right: 0;
}

.list-group {
  padding-left: 0px;
  list-style: none;
}

.list-group-item {
  border-bottom: 1px solid #e7eaec;
  border-top: 1px solid #e7eaec;
  margin-bottom: -1px;
  padding: 11px 0px;
  font-size: 13px;
}

.text-center {
  display: flex;
  justify-content: center;
  width: 100%;
  padding: 10px 0 15px 0;
}
</style>